% !TeX root = ../install-latex-guide-zh-cn.tex

\chapter{Ubuntu 24.04 系统}

\section{安装 \TeX~Live}\label{chap:ubuntu:sec:install}

这里只阐述如何用镜像安装.
为保证用户顺利使用 \TeX~Live 2025,
建议用户首先卸载从源内安装的 \TeX~Live 的相关包,
具体方法见 \ref{sec:ubuntu:uninstall}~节.
由于后续内容涉及字体和文本编辑,
建议用户先确定系统内是否已经有 "fontconfig" 和 "gedit",
它们在较新的 Ubuntu 中是默认安装的,
但如果它们并不存在,
需在 \textsf{Terminal} 中执行
\begin{lstlisting}
  sudo apt install fontconfig gedit
\end{lstlisting}
鉴于大陆地区的网络环境,
建议在执行命令前更换 Ubuntu 源,
参考 \ref{sec:addition:source}~节.
以下未特别说明的命令均在 \textsf{Terminal} 中执行.

下载
\href{https://mirrors.ctan.org/systems/texlive/Images/texlive2025.iso}{\texttt{iso} 镜像文件}
的方法见 \ref{sec:windows:install}~节.
下载完毕后,
验证 MD5 值,
即执行以下命令
\begin{lstlisting}
  cd ~/Downloads
  md5sum texlive2025.iso
\end{lstlisting}
若显示
\begin{lstlisting}
  69b4a8882983d9ea521730b5f42175e7  texlive2025.iso
\end{lstlisting}
则镜像文件下载正确.
同样可验证 SHA512 值,
执行
\begin{lstlisting}
  cd ~/Downloads
  sha512sum texlive2025.iso
\end{lstlisting}
正确的返回结果为
\begin{lstlisting}[literate={a}{a}{1} {b}{b}{1} {c}{c}{1} {d}{d}{1} {e}{e}{1} {f}{f}{1}]
  1fd9a2234d086f50c832ab3ac8b83477bbc39b1138a3c4a2351244c1fd4b8bea6d1ac81d4a5b0cba95f2e82c00f0d9df5b33189eb222e4bae5dae1523ef0da0e  texlive2025.iso
\end{lstlisting}

将下载的光盘镜像进行装载
\begin{lstlisting}
  sudo mkdir /mnt/texlive
  sudo mount ./texlive2025.iso /mnt/texlive
\end{lstlisting}
接下来执行
\begin{lstlisting}
  sudo /mnt/texlive/install-tl
\end{lstlisting}
进行安装.
在屏幕上应该能见到以下内容
\begin{lstlisting}[language = {}, deleteemph = set]
  ======================> TeX Live installation procedure <=====================

  ======>   Letters/digits in <angle brackets> indicate   <=======
  ======>   menu items for actions or customizations      <=======
  = help>   https://tug.org/texlive/doc/install-tl.html   <=======

   Detected platform: GNU/Linux on x86_64

   <B> set binary platforms: 1 out of 15

   <S> set installation scheme: scheme-full

   <C> set installation collections:
       40 collections out of 41, disk space required: 8779 MB (free: 974100 MB)

   <D> set directories:
     TEXDIR (the main TeX directory):
       /usr/local/texlive/2025
     TEXMFLOCAL (directory for site-wide local files):
       /usr/local/texlive/texmf-local
     TEXMFSYSVAR (directory for variable and automatically generated data):
       /usr/local/texlive/2025/texmf-var
     TEXMFSYSCONFIG (directory for local config):
       /usr/local/texlive/2025/texmf-config
     TEXMFVAR (personal directory for variable and automatically generated data):
       ~/.texlive2025/texmf-var
     TEXMFCONFIG (personal directory for local config):
       ~/.texlive2025/texmf-config
     TEXMFHOME (directory for user-specific files):
       ~/texmf

   <O> options:
     [ ] use letter size instead of A4 by default
     [X] allow execution of restricted list of programs via \write18
     [X] create all format files
     [X] install macro/font doc tree
     [X] install macro/font source tree
     [ ] create symlinks to standard directories
     [X] after install, set CTAN as source for package updates

   <V> set up for portable installation

  Actions:
   <I> start installation to hard disk
   <P> save installation profile to 'texlive.profile' and exit
   <Q> quit

  Enter command:
\end{lstlisting}
点击键盘 \keys{I} 进行默认安装,
默认安装是为\textbf{所有用户}安装.
如果用户对于 Ubuntu 系统比较了解,
可以根据提示,
更改安装设置,
如安装路径等.
为简化起见,
以下记录均假定为 \path{x86_64} 上的默认安装.
安装完毕后,
系统会提示用户添加环境变量,
例如
\begin{lstlisting}[deletekeywords = local]
  export PATH=/usr/local/texlive/2025/bin/x86_64-linux:$PATH
  export MANPATH=/usr/local/texlive/2025/texmf-dist/doc/man:$MANPATH
  export INFOPATH=/usr/local/texlive/2025/texmf-dist/doc/info:$INFOPATH
\end{lstlisting}
此处显示信息可能会略有不同,
比如电脑使用了基于 \texttt{arm64} 架构的处理器,
则 \path{x86_64-linux} 将被替换为 \path{aarch64-linux}.
为安全起见,
用户需将此处的系统提示记录.

将装载的光盘镜像弹出并删除文件夹,
即执行
\begin{lstlisting}
  sudo umount /mnt/texlive
  sudo rm -r /mnt/texlive
\end{lstlisting}

设置环境变量.
执行
\begin{lstlisting}
  gedit ~/.profile
\end{lstlisting}
在打开的文件末尾添加刚刚记录的系统提示,
如
\begin{lstlisting}[deletekeywords = local]
  # Add TeX Live to the PATH, MANPATH, INFOPATH
  export PATH=/usr/local/texlive/2025/bin/x86_64-linux:$PATH
  export MANPATH=/usr/local/texlive/2025/texmf-dist/doc/man:$MANPATH
  export INFOPATH=/usr/local/texlive/2025/texmf-dist/doc/info:$INFOPATH
\end{lstlisting}
并保存退出.
然后退出当前用户并重新登录,
再打开 \textsf{Terminal} 并执行
\begin{lstlisting}
  tex -v
\end{lstlisting}
若显示
\begin{lstlisting}[language = {}]
  TeX 3.141592653 (TeX Live 2025)
  kpathsea version 6.4.1
  Copyright 2025 D.E. Knuth.
  There is NO warranty.  Redistribution of this software is
  covered by the terms of both the TeX copyright and
  the Lesser GNU General Public License.
  For more information about these matters, see the file
  named COPYING and the TeX source.
  Primary author of TeX: D.E. Knuth.
\end{lstlisting}
即为安装成功.

接下来处理字体.
在 \textsf{Terminal} 中执行
\begin{lstlisting}[deletekeywords = local]
  sudo cp /usr/local/texlive/2025/texmf-var/fonts/conf/texlive-fontconfig.conf /etc/fonts/conf.d/09-texlive.conf
\end{lstlisting}
将配置文件复制到系统,
然后继续执行
\begin{lstlisting}
  sudo fc-cache -fsv
\end{lstlisting}
刷新字体缓存.
这样一来, \TeX~Live 中的字体才能够被正确调用.
更多内容请参考 \href{https://tug.org/texlive/doc/texlive-zh-cn/texlive-zh-cn.pdf}{\textsf{texlive-zh-cn}}.

如果用户更改了安装路径,
要注意将
\begin{lstlisting}[language = {}]
  /usr/local/texlive/2025/
\end{lstlisting}
在各处替换.

\subsection{为个人用户安装}\label{subsec:ubuntu-user-folder}

如果用户只打算为\textbf{个人用户}安装 \TeX~Live,
那么可以不必调用权限,
直接执行
\begin{lstlisting}
  /mnt/texlive/install-tl
\end{lstlisting}
只不过这时安装路径需要选择在个人用户文件夹下,
例如
\begin{lstlisting}
  ~/.local/texlive/2025/
\end{lstlisting}
安装完毕后,
继续修改环境变量为
\begin{lstlisting}
  # Add TeX Live to the PATH, MANPATH, INFOPATH
  export PATH=~/.local/texlive/2025/bin/x86_64-linux:$PATH
  export MANPATH=~/.local/texlive/2025/texmf-dist/doc/man:$MANPATH
  export INFOPATH=~/.local/texlive/2025/texmf-dist/doc/info:$INFOPATH
\end{lstlisting}
有关字体的处理变为%
\footnote{这里并未使用
\href{https://tug.org/texlive/doc/texlive-zh-cn/texlive-zh-cn.pdf}{\textsf{texlive-zh-cn}}
中建议的路径 \path{~/.fonts.conf.d/},
因为根据 \href{https://www.freedesktop.org/software/fontconfig/fontconfig-user.html}{freedesktop} 的说法,
该路径已废弃,
故此处采用新的路径,
即 \path{$XDG_CONFIG_HOME/fontconfig/conf.d/}}
\begin{lstlisting}
  cp ~/.local/texlive/2025/texmf-var/fonts/conf/texlive-fontconfig.conf $XDG_CONFIG_HOME/fontconfig/conf.d/09-texlive.conf
\end{lstlisting}
然后执行
\begin{lstlisting}
  fc-cache -fv
\end{lstlisting}
实际上,
无论将 \TeX~Live 安装到哪里,
字体的配置文件都可以仿照上面只复制于个人用户文件夹中.

\section{升级宏包}\label{sec:ubuntu:update}

默认安装情况下,
由于权限问题,
直接使用 "tlmgr" 升级宏包会失败,
但如果使用 "sudo" 执行,
会显示 "tlmgr" 命令不存在,
因为 "sudo" 默认没有加载它为环境变量，
这里提供几种方法解决该问题.
至于为个人用户安装,
下述的 "tlmgr" 命令可以脱离 "sudo" 使用.
后续内容类似,
不再赘述.

\subsection{权限修改}

此种方法是我在个人电脑上最常用的方法,
但因为它有可能造成安全漏洞,
因此\textbf{不建议新用户使用}.
首次升级前,
执行
\begin{lstlisting}
  sudo visudo
\end{lstlisting}
在 \path{secure_path} 后面添加
\begin{lstlisting}[language = {}]
  /usr/local/texlive/2025/bin/x86_64-linux:
\end{lstlisting}
然后依次 \keys{\ctrl + X}, \keys{Y}, \keys{\enter} 保存退出.
接下来在 \textsf{Terminal} 中执行
\begin{lstlisting}
  sudo tlmgr option repository ctan
\end{lstlisting}
让系统自动选择源,
用户也可以选择大陆地区的源进行升级,
详情见附录~\ref{chp:appendix:mirror}.
执行命令
\begin{lstlisting}
  sudo tlmgr update --list
\end{lstlisting}
可查看目前源上可升级的宏包都有哪些.
高级用户可以根据自己的需求选择升级特定宏包.
建议初级用户执行
\begin{lstlisting}
  sudo tlmgr update --self --all
\end{lstlisting}
同时升级 "tlmgr" 本身和全部宏包.

\subsection{使用绝对路径}

此方法通过调用 "which" 命令来查找 "tlmgr" 的绝对路径,
例如让系统自动选择源
\begin{lstlisting}
  sudo $(which tlmgr) option repository ctan
\end{lstlisting}
升级 "tlmgr" 本身和全部宏包
\begin{lstlisting}
  sudo $(which tlmgr) update --self --all
\end{lstlisting}

\subsection{保持环境变量}

由于前期已经配置好了 "PATH",
因此可以直接用
\begin{lstlisting}
  sudo env PATH="$PATH" tlmgr option repository ctan
  sudo env PATH="$PATH" tlmgr update --self --all
\end{lstlisting}

\subsection{修改目录权限}

首先更改安装路径所有权为当前用户
\begin{lstlisting}
  sudo chown -R $USER:$USER /usr/local/texlive/2025
\end{lstlisting}
然后就可直接脱离 "sudo" 运行
\begin{lstlisting}
  tlmgr option repository ctan
  tlmgr update --self --all
\end{lstlisting}
如果想恢复权限,
执行
\begin{lstlisting}
  sudo chown -R root:root /usr/local/texlive/2025
  sudo chmod -R 755 /usr/local/texlive/2025
\end{lstlisting}

\section{安装宏包}\label{sec:ubuntu:installpackage}

Ubuntu 24.04 下安装宏包的要求与 Windows 11 下没有多少区别, 只需注意权限, 例如
\begin{lstlisting}
  sudo tlmgr install mcmthesis
\end{lstlisting}
即安装了 \texttt{mcmthesis} 宏包.

\section{调出宏包手册}\label{sec:ubuntu:texdoc}

与 Windows 11 类似,
当正确安装后,
用户可以调出宏包手册以查阅相应内容.
例如在 \textsf{Terminal} 中执行
\begin{lstlisting}
  texdoc texlive-zh-cn
  texdoc lshort-zh-cn
  texdoc install-latex-guide-zh-cn
\end{lstlisting}
就可分别调出 \texttt{texlive-zh-cn.pdf},
\texttt{lshort-zh-cn.pdf}
或本手册.

\section{编译文档}

首先, 用户需要在工作路径建立一个 \texttt{tex} 文件.
在 \textsf{Terminal} 中执行
\begin{lstlisting}[deletekeywords = tex]
  mkdir ~/Documents/work-latex
  cd ~/Documents/work-latex/
  gedit main.tex
\end{lstlisting}
在打开的文件输入一个最小示例
\begin{lstlisting}[language = mwe]
  \documentclass{article}
  \begin{document}
    Hello \LaTeX\ World!
  \end{document}
\end{lstlisting}
保存并退出.
接下来执行
\begin{lstlisting}
  pdflatex main
\end{lstlisting}
等待系统完成编译过程.
待编译完成后,
我们即可看到在 \path{~/Documents/work-latex/} 中出现了
\texttt{main.pdf} 文件和其他同名的辅助文件 \texttt{main.aux} 与
\texttt{main.log}.
执行
\begin{lstlisting}
  evince main.pdf
\end{lstlisting}
即可打开 \texttt{pdf} 文件.

对于中文文档, 可以在 "gedit" 中编写以下最小示例\footnote{"gedit" 默认使用 UTF-8 编码}%
\begin{lstlisting}[language = mwe]
  \documentclass[fontset = fandol]{ctexart}
  \begin{document}
    你好 \LaTeX\ 世界！
  \end{document}
\end{lstlisting}
保存并退出.
接下来执行
\begin{lstlisting}
  xelatex main
\end{lstlisting}
等待系统完成编译过程.
"xelatex" 可以使用系统内安装的字体,
安装字体的方法可参考 \ref{sec:addition:font}~节.

编译命令可添加参数, 这里与 \ref{sec:windows:compile}~节中的情形一致.

\section{卸载 \TeX~Live}\label{sec:ubuntu:uninstall}

下面提供几种卸载方法,
卸载后需注意清理环境变量.

\subsection{卸载源内的版本}\label{sec:ubuntu:aptremove}

如果要卸载从源内安装的 \TeX~Live, 个人比较推荐使用 \texttt{synaptic package manager}.
在 \textsf{Terminal} 中执行
\begin{lstlisting}
  sudo apt install synaptic
\end{lstlisting}
即可安装.
安装后打开, 搜索 \textsf{texlive} 即可看到与之相关的包, 右键标记以删除即可.
当然, 用户也可以直接使用
\begin{lstlisting}
  dpkg -l | grep 'TeX Live'
\end{lstlisting}
找到相应的包名 \texttt{<package name>}, 之后使用类似
\begin{lstlisting}
  sudo apt autoremove --purge <package name>
\end{lstlisting}
的命令删除各个包.
通常
\begin{lstlisting}
  sudo apt autoremove --purge tex-common
\end{lstlisting}
就可以删除源内版本.

\subsection{手动卸载}

如果是从光盘镜像安装,
直接删除文件夹即可.
先在\textsf{Terminal} 中执行
\begin{lstlisting}
  kpsewhich -var-value TEXMFROOT
\end{lstlisting}
来查询安装路径,
进而通过 "sudo rm -rf" 命令进行删除.
默认安装的用户直接运行
\begin{lstlisting}[deletekeywords = local]
  sudo rm -rf /usr/local/texlive/2025
  rm -rf ~/.texlive2025
\end{lstlisting}
卸载完成后, 可以进一步移除之前设置的环境变量.
在 \textsf{Terminal} 中执行
\begin{lstlisting}
  gedit ~/.profile
\end{lstlisting}
然后移除之前在文件末尾添加的
\begin{lstlisting}[deletekeywords = local]
  # Add TeX Live to the PATH, MANPATH, INFOPATH
  export PATH=/usr/local/texlive/2025/bin/x86_64-linux:$PATH
  export MANPATH=/usr/local/texlive/2025/texmf-dist/doc/man:$MANPATH
  export INFOPATH=/usr/local/texlive/2025/texmf-dist/doc/info:$INFOPATH
\end{lstlisting}
并保存退出.
同时在 \textsf{Terminal} 中执行
\begin{lstlisting}
  sudo visudo
\end{lstlisting}
在 \path{secure_path} 中删除
\begin{lstlisting}[deletekeywords = local]
  /usr/local/texlive/2025/bin/x86_64-linux:
\end{lstlisting}
然后依次 \keys{\ctrl + X}, \keys{Y}, \keys{\enter} 保存退出.

\subsection{使用 \texttt{tlmgr} 工具}

同样,
用户也可以使用 "tlmgr" 工具卸载%
\footnote{"sudo tlmgr" 无法使用的情况可以参考 \ref{sec:ubuntu:update}~节 解决},
\begin{lstlisting}
  sudo tlmgr remove --all
\end{lstlisting}

\section{跨版本升级 \TeX~Live}\label{sec:ubuntu:version}

在 \href{https://www.tug.org/texlive/upgrade.html}{\texttt{tug.org}}
网站上提供了相应的方法.
但网站也声明:
默认情况下,
请通过执行新安装来获取新版本的 \TeX~Live%
\footnote{原文是: By default,
please get the new TL by doing a new installation instead of proceeding here}.
